import { createVNode, render } from 'vue'
import XtxConfirm from './xtx-confirm.vue'

// 准备一个DOM
const div = document.createElement('div')
div.setAttribute('class', 'xtx-confirm-container')
document.body.appendChild(div)

// 返回的是promise对象，点击取消和确认都要销毁组件
export default ({ title, text }) => {
  // 1.导入被创建的组件
  // 2.使用createVNode创建虚拟节点
  // 3.准备DOM容器装载组件
  // 4.使用render函数渲染组件到容器

  return new Promise((resolve, reject) => {
    // 点击取消按钮的回调函数
    const cancelCallback = () => {
      render(null, div)
      reject(new Error('点击取消'))
    }
    // 点击确认按钮的回调函数
    const submitCallback = () => {
      render(null, div)
      resolve()
    }
    // 将上述两个方法返回给XtxConfirm组件
    const vn = createVNode(XtxConfirm, { title, text, cancelCallback, submitCallback })
    render(vn, div)
  })
}
